//给定一组非负整数，重新排列它们的顺序使之组成一个最大的整数。 
//
// 示例 1: 
//
// 输入: [10,2]
//输出: 210 
//
// 示例 2: 
//
// 输入: [3,30,34,5,9]
//输出: 9534330 
//
// 说明: 输出结果可能非常大，所以你需要返回一个字符串而不是整数。 
// Related Topics 排序 
// 👍 378 👎 0

package leetcode.editor.cn;

import common.util.MyUtil;

import java.util.Arrays;

/**
 * Java：最大数
 *
 * @author changgui
 */
@SuppressWarnings("all")
public class P179_LargestNumber {
    public static void main(String[] args) {
        Solution solution = new P179_LargestNumber().new Solution();
        int[] array = MyUtil.createArray(74, 21, 33, 51, 77, 51, 90, 60, 5, 56);
        MyUtil.print(solution.largestNumber(array));
    }

    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        public String largestNumber(int[] nums) {
            StringBuilder sb = new StringBuilder();
            String[] strs = new String[nums.length];
            for (int i = 0; i < nums.length; i++) {
                strs[i] = String.valueOf(nums[i]);
            }
            Arrays.sort(strs, (o1, o2) -> {
                return (o2 + o1).compareTo(o1 + o2);
            });
            if ("0".equals(strs[0])) {
                return "0";
            }
            for (String str : strs) {
                sb.append(str);
            }
            return sb.toString();
        }
    }
    //leetcode submit region end(Prohibit modification and deletion)

}